#pragma once

#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
#include<stdbool.h>

typedef int QDdataType;

typedef struct QNode
{
    QDdataType data;
    struct QNode* next;
}QNode;

typedef struct Queue
{
    QNode* head;
    QNode* tail;
    int size;
}Queue;

bool QEmpty(Queue* pq);

int QSize(Queue* pq);

void QInit(Queue* pq);

void QDestroy(Queue* pq);

void QPush(Queue* pq, QDdataType x);

void QPop(Queue* pq);

QDdataType QFront(Queue* pq);

QDdataType QBack(Queue* pq);
